package com.archer.task04;

import java.util.concurrent.atomic.AtomicReference;

public class ThreadJoin {

    public static void main(String[] args) throws InterruptedException {
        long start=System.currentTimeMillis();

        // 在这里创建一个线程或线程池，
        // 异步执行 下面方法

        AtomicReference<Integer> value = new AtomicReference<>(0);
        Thread thread = new Thread(() -> {
            value.set(sum());
        });
        thread.start();
        thread.join();

        Integer result = value.get(); //这是得到的返回值

        // 确保  拿到result 并输出
        System.out.println("异步计算结果为："+result);

        System.out.println("使用时间："+ (System.currentTimeMillis()-start) + " ms");

        // 然后退出main线程
    }

    private static Integer sum(){
        return fibo(36);
    }

    private static Integer fibo(int a) {
        if ( a < 2)
            return 1;
        return fibo(a-1) + fibo(a-2);
    }
}
